iT邦幫忙

2024 iThome 鐵人賽

DAY 1
1

聯繫我

如果有任何問題或建議,歡迎隨時聯繫我:

介紹

歡迎來到 JavaScript 新手到高手:現代特性全攻略 系列文章!這個系列旨在幫助你掌握現代 JavaScript 的各種特性,從基本概念到進階應用,讓你一天接著一天成為
JavaScript 的高手。

在接下來的30天中,我們會每天探討一個新的主題,然而現在 GPT、網路社群發達,所以在之後的文章更傾向於自己去尋找並整理出自己的看法,也很歡迎提問以及討論哦!

對於常使用到的 檢查工具 或是 安裝方法 這邊會略微帶過並更專注於 JavaScript
的運用,通過實際範例和詳細講解,幫助大家理解並應用這些特性。

為了可以針對某些技術做學習,以下目錄方便大家針對相關技術文章做導頁。

目錄

天數 主題 描述
Day 1 ES6+ 簡介及環境設置 簡介 ES6+ 的背景和重要性,並設置開發環境。
Day 2 變量聲明:let 和 const 深入探討 let 和 const 的變量聲明方式,以及與 var 的區別。
Day 3 箭頭函數與模板字面量 介紹箭頭函數和模板字面量的語法和應用,解決 this 綁定問題。
Day 4 解構賦值與擴展運算符 講解解構賦值和擴展運算符的基本用法和應用場景。
Day 5 函數參數預設值與 Symbol 介紹函數參數預設值的使用方法及 Symbol 的概念與應用。
Day 6 迴圈:for...of 和迭代器 探討 for...of 迴圈和迭代器的基本概念和使用方法。
Day 7 Array 和 String 的新方法 講解 ES6+ 為 Array 和 String 添加的新方法及其應用。
Day 8 Number 和 Object 的新方法 介紹 ES6+ 中 Number 和 Object 的新方法。
Day 9 Math 的新方法 介紹 ES6+ 中 Math 對象的新方法。
Day 10 Promises 基礎與進階 探討 Promises 的基本概念和進階用法,幫助處理異步操作。
Day 11 async/await 基礎與進階 深入介紹 async/await 的基礎概念及其進階應用,簡化異步代碼。
Day 12 事件循環概念與詳解 解釋 JavaScript 的事件循環機制,幫助理解非阻塞 I/O。
Day 13 非阻塞 I/O 概念與應用 介紹非阻塞 I/O 的概念和應用場景,提升代碼性能。
Day 14 類別與繼承 深入探討 ES6+ 的類別與繼承機制,模擬傳統面向對象編程。
Day 15 靜態方法與存取器 介紹類別中的靜態方法和存取器的使用方法。
Day 16 類別中的私有字段 講解類別中的私有字段及其應用。
Day 17 模組化 介紹 ES6+ 模組化機制及其使用方法,提升代碼可維護性。
Day 18 Proxy 和 Reflect 探討 Proxy 和 Reflect 對象的基本用法和應用場景。
Day 19 Set 和 WeakSet 介紹 Set 和 WeakSet 這兩種集合對象及其應用。
Day 20 Map 和 WeakMap 介紹 Map 和 WeakMap 這兩種集合對象及其應用。
Day 21 生成器與進階應用 深入探討生成器的基礎和進階應用,幫助處理異步流程。
Day 22 可選鏈式操作符 介紹可選鏈式操作符的使用方法及其應用。
Day 23 Nullish 合併運算符 講解 Nullish 合併運算符的基本概念及其應用場景。
Day 24 BigInt 介紹 BigInt 的基本概念及其應用場景。
Day 25 全局對象:globalThis 介紹 globalThis 對象及其使用方法。
Day 26 高階函數:map、filter、reduce 介紹常見的高階函數 map、filter 和 reduce 及其應用。
Day 27 簡化的異步處理 介紹簡化異步處理的方法和技巧,提升代碼可讀性。
Day 28 進階正則表達式技巧 介紹正則表達式的進階技巧和應用場景,提升字符串處理能力。
Day 29 擴展運算符的高級用法 深入探討擴展運算符的高級用法及其應用場景。
Day 30 現代 JavaScript 項目最佳實踐 分享現代 JavaScript 項目的最佳實踐,提升開發效率和代碼質量。

Day 1: ES6+ 簡介及快速開始

介紹

在第一天,我們將介紹 ES6+ 的背景和重要性,並幫助你快速設置一個開發環境,讓你能夠運行第一個 JavaScript 程式 "Hello World"。

ES6+ 的背景與重要性

在開始之前我們可以簡單的了解 JavaScript 發展歷程,ES6 的出現及其對 JavaScript 的重大改進!

JavaScript 誕生就不特別贅述,然而作為一個重要的標準化角色,這邊要對 ECMAScript 做特別說明:

  • 1995 年,Brendan Eich 在網景公司(Netscape)創建了 JavaScript,以便於在網頁上進行客戶端腳本編寫,增強用戶交互體驗。
  • 隨著 JavaScript 的流行,微軟推出了自己的腳本語言 JScript,這導致了瀏覽器之間的不兼容問題。
  • 為了解決這一問題,Netscape 將 JavaScript 提交給 ECMA 國際標準化組織,促使其成為一個標準語言。

ECMAScript 的版本

1997 年時 ECMAScript 1 發布了 第一版 ECMAScript 標準,在這期間更新了許多新的方法,甚至每年還在持續更新新的版本哦!

至於又為何大家比較常提到 ES6 呢? 那是因為ES6,即 ECMAScript 2015,是 JavaScript 的一個重大版本更新,帶來了大量的新特性和語法改進,使得
JavaScript 語言變得更強大和現代化。

然而這些重大更新例如: 新的變量聲明方式、簡化了函數的語法、 多行字符串和嵌入表達式的功能...等,都會在之後幾天的文章說到 。

至於最在意的是如果我接下來學習新的方法,要怎麼確保瀏覽器有支援呢?
這時候推薦大家可以使用 Can I use 看看可不可以使用哦!

在黃框中輸入語法就可以看到目前瀏覽器的支援度等等資訊,甚至 CSS 也可以查詢哦!

Can I use

選擇代碼編輯器及安裝 Node.js 和 npm

選擇代碼編輯器

工具百百種,這裡建議大家可以先以最廣泛支持度最高的先做練習,這裡以常見的 Visual Studio Code (VS Code) 做示範。

  • 下載和安裝
    • 前往 VS Code 官方網站,下載適合的操作系統版本。
    • 運行下載的安裝程序,按照提示完成安裝。

安裝 Node.js 和 npm

Node.js 是以 V8 為核心,讓電腦可以以 Command line 的方式去執行 JavaScript,所以這邊一起來安裝吧!

  • 下載和安裝

    • 前往 Node.js 官方網站,下載最新的 LTS(長期支持)版本。
    • 運行下載的安裝程序,按照提示完成安裝。
  • 確認安裝

    • 安裝 Node.js 的同時會自動安裝 npm
    • 打開終端(命令提示符)並輸入以下命令,確認 Node.js 和 npm 是否安裝成功:
      node -v
      npm -v
      

為什麼需要安裝 Node.js 和 npm

JavaScript 本身是一種可以在瀏覽器中運行的腳本語言,因此在瀏覽器中運行 JavaScript 代碼是不需要安裝 Node.js 和 npm 的。然而,當涉及到現代 JavaScript 開發,尤其是涉及到開發工具、模組管理和構建過程時,安裝 Node.js 和 npm 是非常常見且推薦的做法!

  1. 開發工具

    • 現代 JavaScript 開發通常需要使用構建工具和打包工具(如 Webpack、Babel),這些工具大多基於 Node.js。
    • npm 是 Node.js 的包管理工具,用於安裝和管理這些工具。
  2. 模組管理

    • npm 提供了豐富的 JavaScript 庫和模組,可以方便地在項目中使用。
    • 通過 npm,你可以輕鬆地管理項目的依賴關係,並確保版本一致性。
  3. 本地開發服務器

    • Node.js 可以用於啟動本地開發服務器,方便測試和開發。
    • 常見的開發服務器工具如 Express、lite-server 等。

一起快速看到成果!

  1. 打開 VSCode
    在新的資料夾內新增一個新的 HelloWorld.js 的檔案

    VS Code 安裝

  2. 輸入程式碼

    • HelloWorld.js 檔案中輸入如下指令:
      console.log("Hello World!");
      
      console.log("一起成為 JavaScript 的高手!");
      
    • 按下 Ctrl + ~ 打開 VSCode 終端機(Windows)。
    • 在終端機中輸入以下命令來運行 HelloWorld.js 檔案:
      node HelloWorld.js
      

就這樣完成了第一次的程式碼運行!

VS Code 安裝

故障排除步驟

如果你沒有看到預期的輸出,請檢查以下幾個方面:

  1. 文件名稱和路徑

    • 確保你在終端機中運行的文件名稱和實際文件名稱一致。
    • 確保你在終端機中所處的路徑是包含 HelloWorld.js 文件的目錄。
  2. Node.js 安裝

    • 確保 Node.js 已經正確安裝,並且可以在終端機中正常運行。可以輸入以下命令來檢查 Node.js 版本:
      node -v
      
    • 如果沒有輸出版本號,請重新安裝 Node.js。
  3. 代碼錯誤

    • 檢查你的 HelloWorld.js 文件中的代碼是否有拼寫錯誤或語法錯誤。確保代碼與提供的範例一致。

本篇自我挑戰

何謂自我挑戰,問題不怕困難,重點是要解決出問題的人(誤,嘗試開始! 在這裡你可以看到大家是怎麼回答題目的,甚至會看到暗藏的高手可以將簡單的題目回答的淋漓盡致!回答我都會放在隔天的 GitHub Day2 JS 上哦!

  • 今日挑戰:有沒有辦法自己 console.log 出一個屬於自己的文字?
  • 反思:有沒有辦法在 console.log 裡面做數學運算呢?

總結

在第一天的學習中,我們了解了 ES6+ 的背景和重要性,並設置了一個快速的開發環境,運行了第一個JavaScript 程式 "Hello World"。 歡迎在討論區互動交流,我們將在下一篇探討 變數!


下一篇
【Day 2】變量聲明:let 和 const
系列文
JavaScript 新手到高手:現代特性全攻略30
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

尚未有邦友留言

立即登入留言